package com.ruoyi.system.service.impl;

import cn.hutool.core.lang.Validator;
import cn.hutool.core.util.StrUtil;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.ruoyi.common.constant.UserConstants;
import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl;
import com.ruoyi.common.core.page.TableDataInfo;
import com.ruoyi.common.exception.CustomException;
import com.ruoyi.common.utils.PageUtils;
import com.ruoyi.system.domain.SysPost;
import com.ruoyi.system.domain.SysUserPost;
import com.ruoyi.system.mapper.SysPostMapper;
import com.ruoyi.system.mapper.SysUserPostMapper;
import com.ruoyi.system.service.ISysPostService;
import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import java.util.Arrays;
import java.util.List;

/**
 * 岗位信息 服务层处理
 *
 * @author ruoyi
 */
@Service
public class SysPostServiceImpl extends ServicePlusImpl<SysPostMapper, SysPost> implements ISysPostService {

	@Autowired
	private SysUserPostMapper userPostMapper;

	@Override
	public TableDataInfo<SysPost> selectPagePostList(SysPost post) {
		LambdaQueryWrapper<SysPost> lqw = new LambdaQueryWrapper<SysPost>()
			.like(StrUtil.isNotBlank(post.getPostCode()), SysPost::getPostCode, post.getPostCode())
			.eq(StringUtils.isNotBlank(post.getIsEnable()), SysPost::getIsEnable, post.getIsEnable())
			.like(StrUtil.isNotBlank(post.getPostName()), SysPost::getPostName, post.getPostName());
		return PageUtils.buildDataInfo(page(PageUtils.buildPage(), lqw));
	}

	/**
	 * 查询岗位信息集合
	 *
	 * @param post 岗位信息
	 * @return 岗位信息集合
	 */
	@Override
	public List<SysPost> selectPostList(SysPost post) {
		return list(new LambdaQueryWrapper<SysPost>()
			.like(StrUtil.isNotBlank(post.getPostCode()), SysPost::getPostCode, post.getPostCode())
			.eq(StrUtil.isNotBlank(post.getIsEnable()), SysPost::getIsEnable, post.getIsEnable())
			.like(StrUtil.isNotBlank(post.getPostName()), SysPost::getPostName, post.getPostName()));
	}

	/**
	 * 查询所有岗位
	 *
	 * @return 岗位列表
	 */
	@Override
	public List<SysPost> selectPostAll() {
		return list();
	}

	/**
	 * 通过岗位ID查询岗位信息
	 *
	 * @param postId 岗位ID
	 * @return 角色对象信息
	 */
	@Override
	public SysPost selectPostById(Long postId) {
		return getById(postId);
	}

	/**
	 * 根据用户ID获取岗位选择框列表
	 *
	 * @param userId 用户ID
	 * @return 选中岗位ID列表
	 */
	@Override
	public List<Integer> selectPostListByUserId(Long userId) {
		return baseMapper.selectPostListByUserId(userId);
	}

	/**
	 * 校验岗位名称是否唯一
	 *
	 * @param post 岗位信息
	 * @return 结果
	 */
	@Override
	public String checkPostNameUnique(SysPost post) {
		Long postId = Validator.isNull(post.getPostId()) ? -1L : post.getPostId();
		SysPost info = getOne(new LambdaQueryWrapper<SysPost>()
			.eq(SysPost::getPostName, post.getPostName()).last("limit 1"));
		if (Validator.isNotNull(info) && info.getPostId().longValue() != postId.longValue()) {
			return UserConstants.NOT_UNIQUE;
		}
		return UserConstants.UNIQUE;
	}

	/**
	 * 校验岗位编码是否唯一
	 *
	 * @param post 岗位信息
	 * @return 结果
	 */
	@Override
	public String checkPostCodeUnique(SysPost post) {
		Long postId = Validator.isNull(post.getPostId()) ? -1L : post.getPostId();
		SysPost info = getOne(new LambdaQueryWrapper<SysPost>()
			.eq(SysPost::getPostCode, post.getPostCode()).last("limit 1"));
		if (Validator.isNotNull(info) && info.getPostId().longValue() != postId.longValue()) {
			return UserConstants.NOT_UNIQUE;
		}
		return UserConstants.UNIQUE;
	}

	/**
	 * 通过岗位ID查询岗位使用数量
	 *
	 * @param postId 岗位ID
	 * @return 结果
	 */
	@Override
	public int countUserPostById(Long postId) {
		return userPostMapper.selectCount(new LambdaQueryWrapper<SysUserPost>().eq(SysUserPost::getPostId, postId));
	}

	/**
	 * 删除岗位信息
	 *
	 * @param postId 岗位ID
	 * @return 结果
	 */
	@Override
	public int deletePostById(Long postId) {
		return baseMapper.deleteById(postId);
	}

	/**
	 * 批量删除岗位信息
	 *
	 * @param postIds 需要删除的岗位ID
	 * @return 结果
	 * @throws Exception 异常
	 */
	@Override
	public int deletePostByIds(Long[] postIds) {
		for (Long postId : postIds) {
			SysPost post = selectPostById(postId);
			if (countUserPostById(postId) > 0) {
				throw new CustomException(String.format("%1$s已分配,不能删除", post.getPostName()));
			}
		}
		return baseMapper.deleteBatchIds(Arrays.asList(postIds));
	}

	/**
	 * 新增保存岗位信息
	 *
	 * @param post 岗位信息
	 * @return 结果
	 */
	@Override
	public int insertPost(SysPost post) {
		return baseMapper.insert(post);
	}

	/**
	 * 修改保存岗位信息
	 *
	 * @param post 岗位信息
	 * @return 结果
	 */
	@Override
	public int updatePost(SysPost post) {
		return baseMapper.updateById(post);
	}
}
